// pages/login/login.js

// 导入封装通用模块方法
import { toast  } from '../../utils/extendApi'
// 导入本地存储 api
import { setStorage } from '../../utils/storage'
// 导入接口 API 函数
import { reqUserInfo } from '../../api/user'

// 导入 ComponentWithStore 方法
import { ComponentWithStore } from 'mobx-miniprogram-bindings'
// 导入 store 对象
import { userStore } from '../../stores/userstore'

// 导入防抖函数
import { debounce } from 'miniprogram-licia'

// 使用 ComponentWithStore 方法替换 Component 方法构造页面
ComponentWithStore({
  // 让页面和 Store 对象建立关联
  storeBindings: {
    store: userStore,
    fields: ['userInfo'],
    actions: ['setUserInfo']
  },

  methods: {
    // 授权登录
    login: debounce(function () {
      // 使用 wx.login 获取用户的临时登录凭证 code
      wx.login({
        success: async ({ code }) => {
          if (code) {
            console.log('code',code);
            // 在获取到临时登录凭证 code 以后，需要传递给开发者服务器
            const res = await reqUserInfo(code)
            const data  =  { id:res.data?.id, name:res?.name }
           
            // 将用户信息存储到本地
            setStorage('userInfo', data)
            // 将用户信息存储到 Store 对象
            this.setUserInfo(data)
            // 返回上一级页面
            // wx.navigateBack()
            // 登录成功后跳转到首页
            wx.switchTab({
              url: '/pages/index/index', // 首页的路径
            });
          } else {
            setTimeout( () => {
              toast({ title: '授权失败，请重新授权' })
            },100);
          }
        }
      })
    }, 500),

 
    
  }
})
